<template>
  <BasicModal v-bind="$attrs" title="IP 查询" @register="registerModal" @ok="handleSubmit">
    <BasicForm @register="registerForm" />
  </BasicModal>
</template>
<script lang="ts" setup name="SystemAreaModal">
import { getAreaByIp } from '@/api/system/area';
import { BasicForm, useForm } from '@/components/Form';
import { BasicModal, useModalInner } from '@/components/Modal';

import { formSchema } from './area.data';

const [registerForm, { setFieldsValue, resetFields, validate }] = useForm({
  labelWidth: 120,
  baseColProps: { span: 24 },
  schemas: formSchema,
  showActionButtonGroup: false,
  actionColOptions: { span: 23 },
});

const [registerModal, { setModalProps }] = useModalInner(async () => {
  resetFields();
  setModalProps({ confirmLoading: false });
});

async function handleSubmit() {
  try {
    const values = await validate();
    setModalProps({ confirmLoading: true });
    console.info(values);
    const res = await getAreaByIp(values.ip);
    if (res) {
      values.result = res;
      setFieldsValue({ ...values });
    }
  } finally {
    setModalProps({ confirmLoading: false });
  }
}
</script>
